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Subcode and sector synchronization for a data processing system 

The present indention relates to the data synchronization 
between a data processing system and a servo -system for an 
5 apparatus for reading from and/or writing to optical recording 
media. 

In recent years an increasing need hap been experienced for 
providing consumer electronic devices, like e.g. compact disc 

10 players, DVD-players and others, with the capability of 

processing audio data stored* as audio files in a compressed 
(e.g. MP3 or MP3 Pro, WMA (Windows Media Audio)) or 
uncompressed (e.g. WAV (Waveform Audio File)) data format on a 
storage medium. In contrast to an Audio Processing System 

15 according to prior art, which can only read and/or write audio 
information according to the Compact Disa Standard (Red Book) , 
an advanced data processing system (DPS) capable of playing 
back and/or recording audio files in a compressed or 
uncompressed data format, needs to be able to extract, decode, 

20 and convey data related to the file system and the audio files 
stored on a storage medium. 

A CD (compact disc) decoder IC with embedded compressed audio 
decoding shall comprise two primary systems z An advanced data 
25 processing system (DPS) and a servo system (performing servo , 
data path and control operations) . The servo system contains a 
master micro controller. 

Throughout the description, the following definitions are used: 

30 

Sector, Subcode address! 

All sector addresses and subcode time codes (sections) are 
represented in the form min: sec? frame. The minutes field is 
represented by "min", the seconds field is represented by 
35 "sec", the blocks (sector) or frames (subcode) field is 
represented by "frame". 
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Session: 

An area or a disc co nsisting of a Lead-In Area followed by a 

Program Area and a Lead-Out Area is called session, 

5 Single session disc; 

If a disc contains one session, this disc is called a single 
session disc. 

Multisection disc: 
ID If a disc contains more than one session, this disc is called a 
multisession disc. n 

Sector ; 

Whenever the term "sector" is used in this document, it has the 
15 identical meaning as the term "block" in the CD-ROM system 
description. 

DPS* 

(Advanced) Data Processing System-' An example for such a data 
20 processing system is an advanced audio processing system, a 
module responsible for the extraction and interpretation .of 
digital data tracks (Digital Tracks, as defined in ECMA-13 0) in 
a storage medium, as well as decoding and playback of 
compressed audio data contained in the digital data tracks. 

25 

The DPS uses sectors (sector addresses) as itB basic data 
structure while the servo system uses subcode -frames 
(sections) . 

30 The ECMA-13 0 standard provides the following definitions for 
sector and section of a compact disc: 

A sector is the smallest addressable part of the information 
area that can be accessed independently, 

A section (subcode- frame) is defined as a group of 98 F3 -frames 
35 containing a complete table of control bytes. A table is 
generated with the control bytes of each subcode-frame 



c. 
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(section) . The content of this table is renewed every 1/75 
second, which is the same rate at which the subcode -frames are 
being processed. The table of control bytes of a subcode- frame 
defines the following channels: p~, q-, r-, s-, t-, u~, v- and 
5 w-channel of 96 bits each* The receiving end has particular 
interest in the q- channel that conveys r among others , 
information about the absolute time (subcode time code) of the 
section in the A-FRAC, A-SEC and A-MIN fields . These fields 
contain the absolute time in 75th of a second as a continuation 
10 of the time specified in the A-xxx fields of the q-channel of 
the preceding section. 

The address of a sector is recorded in the sector header- The 
address of the first sector with user data of an information 
track is written in the table of contents of the disc, 
15 The sector header conveys the address of a sector as an 

absolute time. At the encoder end, this address is inserted 
just before the Bector enters a Cross Interleaved Reed-Solomon 
(CIRC) encoder. 

20 According to the ECMA 13 0 standard, the nominal value of a 
sector shall be equal to the absolute time recorded in the 
control bytes of that subcode- frame which is being processed by 
the 8 -to- 14 encoder at the time the sync word of the sector 
enters the CIRC encoder. 

25 

It is also stated in the ECMA-13 0 standard that the address of 
the sectors has no prescribed relation to the address (subcode 
time code) of the sections, due to the fact that the mapping of 
a sector to the sections during recording is implementation 
30 dependent (ECMA-13 0 standard, clause 16, Fl Frame) . For this 
reason synchronisation between sectors and subcode-frames is 
required at the receiving end. 

The decoder IC servo system processes the q- channel of the 
35 subcode - frame s . The micro controller has access to the q- 

channel data. Through this it has access to the CP's table of 
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content:. The table of content entries point to the start of 

information tracks on the disc, in terms of the abs olute time 

in the control bytes, with an accuracy of +/- 1 second. 
The mioro controller has also access to the subcode absolute 
5 time code in the q-data field of the information area. 

The DPS requests sectors from the micro controller. The micro 
controller organizes the task of delivering data to the DPS 
with the collaboration of an electronic shock proof micro 
controller (BSPMC) block, from which the DPS receives its input 
10 data, ... # 
The DPS requests sectors using the sector address expressed £n 
absolute time elapsed since the beginning of the user data 
area, in MSF (minutes, seconds, frames) units. The 
corresponding information in the servo system is the absolute 
15 time code part of the q-ohannel of a subcode frame. If no 

synchronisation between the subcode time code and the sector 
address is done, the DPS has to flush the data provided by the 
servo system until the requested data (sector) is received, 
which is time and memory consuming, if the time difference is 
2D known, the servo system can take this information into account 
when jumping to a requested time. 

It is, therefore, an object of the present invention to provide 
a method for synchronizing the pubcode time codes and sector 
25 addresses of data contained on a recording medium. 

According to the invention, the method comprises the steps of: 

- sending a number of sectors from the micro controller to the 
data processing system; 

30 - requesting information about the sector headers of the 
received sectors from the d^ta. processing system? and 

- calculating the difference between the subcode time codes and 
the sector addresses using the information about the sector 
headers , 
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The method has the advantage that it will speed-up the access 
of the data processing system to the sector information 
provided by the servo-system. 

5 Favourably., the method further comprises the steps of • 

- asking the data processing system for a confirmation of 
sector reception; and 

- implementing a continuity counter in the data processing 
system to check if the expected sectors were received. 

10 In this way it is ensured that no- sectors were missed, which 
could otherwise lead to an incorrect synchronization between 
the subcode time codes ^nd the sector addresses. 

Advantageously, the method further comprises the step of 
15 storing the sectors in a memory. This allows further access to 
the sectors by subsequent additional commands from the micro 
controller. 

According to the invention, absolute time information conveyed 
20 in the sector headers and in absolute time fields of the q- 
channel of the subcode frame is used for calculating the 
difference between the subcode time codes and the sector 
addresses- Using this information the synchronization between 
the subcode time codes and the sector addresses can easily be 
25 achieved. 

Favourably, the method further comprises the step of repeating 
the synchronisation steps for every session on the recording 
medium- Since the difference can vary for different sessions on 
30 the same disc this ensures synchronization between the subcode 
time codes and the sector addresses for all sessions. 

According to the invention, a communication protocol for the 
communication between a data processing system and a micro 
*5 controller defines a set of commands and messages necessary for 
synchronization between subcode time codes and sector addresses 
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of data contained on a recording medium- Such a communication 
protocol allows to synchronise between two systems, where one 
system is working based on subcode information, and the other 
system is working based on sector information, 

5 

Advantageously, the set of commands and messages defined for 
the communication protocol comprises commands for scanning 
sectors and for reading sector data and messages for sending 
information on the sectors and the read sector data. Prom the 
10 sector data, especially the sector header, all information 
necessary for synchronization can be retrieved. 
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Favourably, a decoder for optical recording media performs a 
method or uses a communication protocol according to the 
15 invent ion - 

i 
i 

According to the invention, the inventive method, the inventive 
communication protocol r and/or the inventive deooder is used in' 
an apparatus for reading from and/or writing to optical 
20 recording media. 

In the following, the implementation of a communication 
protocol according to the invention will be explained in more ! 
detail. Commands are sent from the micro controller to the DPS, 
25 while messages are sent from the DPS to the micro controller. 



Synchronization process s 

After the servo system has finished reading the table of 
content (TOO , in case of single session disc, the micro 
30 controller will start an "analyse mode 1 ' on the DPS. In case of 
a multiaeeaion disc, the analyse mode can be started after the 
TOO of each session is read, or after all TOCs are read. 



Description of command and Message: 
35 Used command: SCAN <f ramexsecxmin> 
Us^d message? SCANM 

- r- 
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Three different Modes for SCAN, depending on the transmitted 
frame :sec:min information are used. 



5 Recpiests to get information about the f irst valid sector which 
can be received from the AIN-Mailbox (Audio- In Mailbox) . 
Before the servo system is sending a SCAN model command to the 
DPS, the ESPMC memory will be flushed and then e„g, 4 subcode 
frames are stored by the esrvo system into the BjSFMC memory, 

10 The storing is to be understood as follows. In a playback mode 
the servo system searches for the specific subcode or jumps to 
the corresponding position on the disc. As soon as the subcode 
has been found, writing of data to the ESPMC is enabled, the 
data coming from an error correction block. When a 

15 predetermined number of subcode -frames, e.g, four subcode- 
frames, has been written to the ESPMC, writing is disabled 
again- The micro controller does not write data to the ESPMC 
directly. 

The storage of data is based on 'the subcode information. By 
20 reading the data in the ESPMC via the DPS the header 

information (sector) can be accessed and the time difference 
between the stored subcode frame and the actually obtained 
sector can be calculated. 

25 Functions 

After receiving the SCAN model command from the servo system, 
the DPS starts reading data out of the AIN-Mailbox, while 
counting the flushed bytes, until a SYNC word, followed by a 
header (1st header, i.e. 12 byte SYNC, followed by 4 bytes of 
30 non flagged data (C2_ERR « 0)) is found. The 1st header 
(4bytes) , followed by 2336 bytes of data will be stored. 

The DPS has to check now, if the following gYNC-word and the 
following header (2nd header, i.e. 12 byte SYNC, followed by 4 
35 bytes of non flagged data (C2_ERR « 0)) are valid. The SYNC- 



Mode 1? 
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word and the 2nd header have to be stored to allow subsequent 



The command will be aborted by the DPS if the BSPMC memory 
5 becomes empty, or in case a number of byte counter has an 
overflow. 

The DPS will send a SGANM message to the servo system, carrying 
information on the 1st and 2nd valid headers r the number of 
10 counted bytes, which were flushed while reading the AHSF-Mailbox 
until the 1st 1 header was found, and an indicator indicating a 
number of byte counter overflow. 

The number of counted bytes should be normally less than the 
15 number of bytes of one sector (2352) . Otherwise, this would be 
an indication for the servo system that one syna-word, 
respectively header was not found. 

The information on the 1st and 2nd valid headers comprises 4 
20 byte header information (1st header) as coded on disc and 8 
byte subheader information (1st header) as coded on disa, and 
indicators indicating whether valid 1st and 2nd headers were 
found. 

25 After receiving the SCANM message, the servo system is able to 
calculate the time difference (in complete sectors) between 
subcode time code and sector addresses as follows: 



30 



time difference = { [m±n = sec : frame] subcode time code stored in 
ESFMC) - { [min: sec: frame] received 1st header information} 



Since only complete sectors can be taken into account by the 
servo system, the DPS has to search for the sync word and has 
to flush number of bytes when the delta is calculated. 
35 The exact delta will be; 
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time difference * {(number o£-byte-12) / 2352} 
Mode 2a 

Requests to search for sector Imin s @ec j frame) within the data 
5 which can be received from the AIN-Mailbox. 

Before the servo system is sending a SCAN mode2 command to the 
DPS, the ESPMC memory will be flushed and then the data to be 
analysed is stored into the ESPMC memory. 

10 Function: 

After receiving the SCAN mode2 command from the servo system, 
the DPS starts reading data out of the AIN- Mailbox, while 
counting the flushed bytes, until a SYNC word, followed by the 
requested header (1st header) is found. The 1st header 
15 (4bytes> , followed by 2336 bytes of data will be stored. 

The DPS has to check: now if the following SYNC-word and the 
following header (2nd header) are valid. The S^NC-word and the 
2nd header have to be remembered to allow subsequent SCAN m©de3 
20 commands to operate on the same ESPMC data. 

The command will be aborted by the DPS if the ESPMC memory 
becomes empty, or in case a number of byte counter has an 
overflow- 

25 

The DPS will send a SCANM message to the servo system, carrying 
information on the 1st and 2nd valid headers, the number of 
counted bytes, which were flushed while reading the AIN-Mailbox 
until the 1st header was found, smd an indicator indicating a 
30 number of byte counter overflow. 

The information on the 1st and 2nd valid headers comprises 4 
byte header information (1st header) as coded on disc and B 
byte subheader information (1st header) as coded on disc, and 
35 indicators indicating whether valid 1st and 2nd headers were 
found . 
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After— rese-i-ving-th^ 

calculate the time difference (number of frames) between 
subcode time code and sector addresses as fallows! 

5 

time difference « {Nlimber of aounted bytes mod 2352} 
Mode 3? 

Requests information about the next sector (2nd valid sector of 
10 the previous scan) which can be received from the AIN~Mailbox„ 
The servo system sends a SCAM mode3 command to the DPS. This 
mode is only applicable, if scan model , scan mode2 or scan 
mode3 was sent before. If no scan was sent before or if no 2nd 
valid header was found before , the error message "command not 
15 available" will be returned. 

Function 

After receiving the SCAN mode3 command from the servo system, 
the DPS continues reading data out of the AIN-Mailbox. The data 
20 will be Btored into*. No bytes will be flushed. 

The header and subheader information of the current sector, 
which was already read by the previous scan model or scan mode2 
command (previous 2nd valid header becomes 1st valid header) , 
will also be stored into. 

25 

The DPS has to check now if the following SYKC-word and the 
following header (new 2nd header) are valid. The SYNC-word and 
the 2nd header have to be stored to allow subsequent SCAN mode3 
commands to operate on the same ESPMC data. 

30 

The command will be aborted by the DPS, if the ESPMC memory 
becomes empty, 

The DPS will send a SCANM message to the servo system, carrying 
35 information about the 1st valid header and about whether * 2nd 
valid header was found- 
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The information about the lat valid header comprises 4 byte 
header information as coded on disc and 8 byte subheader 
information as coded on disc. 

5 

Read sector data: 

As an option/ and also to be flexible for further ahanges in 
the CD-Sector formats , the following access to the cd-rom data 
is proposed* The command and message described below allow to 
10 read the data (header and od-rom data) as stored by previous 
scan commands. 

Description of command and Messages 
Used command: RSECDATA (Request Sector Data) 
15 Used messages SECDATA 

The command^ respectively message is only valid if a SCAN 
command was sent before. Otherwise an error message "command 
not available" will be returned. 

20 The RSECDATA command is called with 2 bytes (lower, higher) 
indicating the first value which will be requested. 

Function 

After receiving the RSECDAT command from the servo system, the 
25 DPS sends the requested data starting at the requested first 
value, to the micro controller using the SECDATA message. 

If the first requested value lies outside an allowed range, the 
error message "target not available" will be returned. 

30 

The inventive method is not limited to the communication in a 
CD-decoder. The method is applicable to any communication 
between two systems, where one system is working based on 
subcode information (like the servo system) , and the other 
35 system is working based on sector information (like the DPS) • 
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For a better understanding of the invention, an exemplary 
jeinkodiment^iB^ 



advantageous configuration with reference to the figure, it is 
understood that the invention is not limited to this exemplary 
embodiment and that specified features can also expediently be 
combined and/or modified without departing from the scope of 
the present invention. 



Fig. 



shows an exanple for the SCAM model communication. 



30 



Fig. 1 shows an example for the 3CAN model'' communication. Upon 
initialization, the micro controller l in a first step 4 has a 
number of sectors sent via a memory 2 (e.g. an electronic shock 
proof micro controller ESPMC) to the DPS 3 . in a second step 5 
the micro controller 1 asks for a confirmation on sector 
reception, which is sent in a further step 6 from the DPS. For 
this purpose a continuity counter 7 is implemented in the DP3, 
To allow synchronization between the subaode time codes and the 
sector addresses, the micro controller in a step 8 requests 
information about the sector header fields using a SCAN model 
command. The DPS sends the requested information using a SCANM 
message. The micro controller is now able to calculate 9 the 
difference between the subcode time codes and the sector 
addresses. In the figure, two further communications steps are 
shown. Using a first read sector data command RSECDATA1, the 
micro controller 1 requests pector data from the DPS 3, which 
in response sendp the requested data using a first sector data 
message SECDATA1. Further data is then exchanged via a second 
read sector data command RSECDATA3 and the corresponding sector 
data response SBCDATA2. ■ 



i 
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Claims 

1, Method for synchronising subcode time codes and sector 
addresses of data contained on a recording medium for the 
5 communication between a data processing system (3) and a micro 
controller (1), comprising the steps of: 

- sending (4) a number of sectors from the micro controller (l) 
to the data processing system (3) ; 

- requesting (8) inf ormation about the sector headers of the 
10 received sectors from the data processing system (3) ; and 

- calculating O) the difference between the subcode time codes 
and the sector addresses using the information about the sector 
headers . 

15 2. Method according to claim 1, further comprising the steps of: 

- asking (5) the data processing system (3) for a confirmation 
of sector reception; and 

- implementing (7) a continuity counter in the data processing 
system (3) to check if the expected sectors were received* 

20 

3. Method according to claim 1 or 2, further comprising the step 
of storing the sectors in a memory (2) . 

4. Method according to any of claims 1-3 , characterised in that 
25 absolute time information conveyed in the sector headers and in 

absolute time fields of the q- channel of the subcode frame is 
used for calculating the difference between the subcode time 
codes and the sector addresses. 

30 5. Method according to any of claims 1-4, further comprising the 
step of repeating the synchronisation steps (4-9) for every 
session on the recording medium. 

6. Communication protocol for the communication between a data 
35 processing system (3) and a micro controller (1) , characterized 
in that a set of commands and messages necessary for 
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synchronisation between subcode time codes and seator addresses 
of dat a co ntained on a recording medium is defined. 

1, Communication protocol according to claim 6, characterised in 
5 that the set of commands and messages comprises commands for 
©aanning sectors and for reading sector data and messages for 
sending information on the sectors and the read sector data. 

B « Decoder for optical recording media, characterized in that it 
10 performs a method according to any of claims 1-5 or uses a 
communication protocol according to claim S or 7. 

9- Apparatus for reading from and/ or writing to optical 
recording media , characterised in that it performs a method 
15 according to any of claims 1-5 , uses a communication protocol 
according to claim 6 or 7, and/or usee a decoder according to 
claim Br." " " — - 
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Abstract 

Subcode and sector synchronization for a data processing system 

5 The present invention relate? to the data synchronization 

between a data* processing system 3 and a servo- system 1 for an 
apparatus for reading from and/or writing to optical recording 
media. 

It is an object of the present invention to provide a . method 
10 for synchronizing the subcode time codes and sector addresses 
of data contained on a recording medium. 

According to the invention, the method comprise© the steps of: 

- sending 4 a number of sectors from the micro controller 1 to 
the data processing system 3; 

15 - requesting 8 information about the sector headers of the 
received sectors from the data processing system 3; and 

- calculating 3 the difference between the subcode time codes 
and the sector addresses using the information about the sector 
headers „ 

20 

Fig. 1 
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